home *** CD-ROM | disk | FTP | other *** search
/ C/C++ Users Group Library 1996 July / C-C++ Users Group Library July 1996.iso / vol_400 / 424_02 / ED-157 / get_markdir.c < prev    next >
C/C++ Source or Header  |  1993-09-10  |  2KB  |  65 lines

  1. /*
  2.  * Copyright (C) 1992 by Rush Record (rhr@clio.rice.edu)
  3.  * 
  4.  * This file is part of ED.
  5.  * 
  6.  * ED is free software; you can redistribute it and/or modify it under the terms
  7.  * of the GNU General Public License as published by the Free Software Foundation.
  8.  * 
  9.  * ED is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
  10.  * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A
  11.  * PARTICULAR PURPOSE.  See the GNU General Public License for more details.
  12.  * 
  13.  * You should have received a copy of the GNU General Public License along with ED
  14.  * (see the file COPYING).  If not, write to the Free Software Foundation, 675
  15.  * Mass Ave, Cambridge, MA 02139, USA.
  16.  */
  17. #include "opsys.h"
  18.  
  19. #include "rec.h"
  20. #include "window.h"
  21. #include "ed_dec.h"
  22.  
  23. /******************************************************************************\
  24. |Routine: get_markdir
  25. |Callby: edit
  26. |Purpose: Figures out in which direction, from the cursor position, a particular
  27. |         spot in the file lies.
  28. |Arguments:
  29. |    rec is the record containing the spot.
  30. |    byt is the byte offset in that record.
  31. \******************************************************************************/
  32. Int get_markdir(rec,byt)
  33. rec_ptr rec;
  34. Int byt;
  35. {
  36.     register rec_ptr forw,back;
  37.  
  38.     if(rec == CURREC)
  39.     {
  40.         if(byt < CURBYT)
  41.             return(-1);
  42.         else if(byt > CURBYT)
  43.             return(1);
  44.         else
  45.             return(0);
  46.     }
  47.     if(rec == BASE)
  48.         return(1);
  49.     if(CURREC == BASE)
  50.         return(-1);
  51.     forw = back = CURREC;
  52.     while(forw != rec && back != rec)
  53.     {
  54.         if((forw = forw->next) == BASE)
  55.             return(-1);
  56.         if((back = back->prev) == BASE)
  57.             return(1);
  58.     }
  59.     if(forw == rec)
  60.         return(1);
  61.     else
  62.         return(-1);
  63. }
  64.  
  65.